# Sparc V8 registers

#### Names of registers visible to a user program at any one time:

| Register | Alias        | Usage                                                          |
|----------|--------------|----------------------------------------------------------------|
| %g0      | %r0          | Hardwired to zero                                              |
| %g1      | %r1          | The next seven are global registers                            |
| %g2      | %r2          |                                                                |
| %g3      | %r3          |                                                                |
| %g4      | %r4          |                                                                |
| %g5      | %r5          |                                                                |
| %g6      | %r6          |                                                                |
| %g7      | %r7          |                                                                |
| %00      | %r8          | First of six registers for local data and subroutine arguments |
| %o1      | %r9          |                                                                |
| %o2      | %r10         |                                                                |
| %o3      | %r11         |                                                                |
| %o4      | %r12         |                                                                |
| %05      | %r13         |                                                                |
| %sp      | %r14,<br>%o6 | Stack pointer                                                  |
| %o7      | %r15         | Linkage register containing subroutine return address          |
| %10      | %r16         | First of eight registers for local variables                   |
| %l1      | %r17         |                                                                |
| %l2      | %r18         |                                                                |
| %l3      | %r19         |                                                                |
| %l4      | %r20         |                                                                |
| %I5      | %r21         |                                                                |
| %l6      | %r22         |                                                                |
| %I7      | %r23         |                                                                |

ep.jhu.edu 1



| Caller                                               | Callee                                               | Usage                                                                                                                    |
|------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| %o0<br>%o1<br>%o2<br>%o3<br>%o4<br>%o5<br>%o6<br>%o7 | %i0<br>%i1<br>%i2<br>%i3<br>%i4<br>%i5<br>%i6<br>%i7 | first argument second argument third argument fourth argument fifth argument sixth argument frame pointer return address |

JOHNS HOPKINS

UNIVERSITY

## Current window pointer (CWP)



There can be up to 32 register windows

Each window contains 24 registers

Windows can slide to pass arguments

Windows overlap

CWP identifies current window

ep.jhu.edu 3 Register Window

Example: function first calls second:



second: save %sp, -80, %sp

restore instruction is used to unwind stack and slide window back

# Register Window



### Sparc V8 registers

#### Special-purpose registers

PC program counter Holds the address of the currently executing instruction

nPC next PC Holds address used to fetch next instruction to be executed

PSR processor state register Holds state of CPU, condition codes, mode, trap enable, bit, etc.

llid mask Indicates when window underflow or overflow should occur

BR trap base register Holds address of trap table and indicates trap type

High part of product for mul; high part of dividend for div

Holds floating point mode and status, controls rounding and floating

point traps

nPC next PC
PSR processor state regis
WIM window-invalid mask
TBR trap base register
Y Y register
FSR floating point state

ep.jhu.edu 6

Floating point unit has a single set of 32 floating point registers

The f Registers

JOHNS HOPKINS

| f[31]    |   |
|----------|---|
| f[30]    |   |
| <u>:</u> |   |
| f[1]     |   |
| f[0]     |   |
| 31       | 0 |

Each float register is 32 bits wide.